草庐IT

SQLite 和并发

全部标签

c# - 如何使用 EF 5.0 Code First 启用并发检查?

我想在原子操作中进行先检查后更新。我正在使用dbcontext来管理事务。如果记录已被另一个线程修改但没有抛出异常,我希望得到一个异常。任何帮助,将不胜感激。这是我的输出:Thread-4:Reading...Thread-5:Reading...Thread-5:Updatingdestination1Thread-4:Updatingdestination1Thread-4:SaveChangesThread-5:SaveChanges这是我的代码片段:publicstaticvoidMain(string[]args){PopulateData();(newThread(Upda

c# - 用于许多并发客户端和数据库访问的 WCF 服务

我是WCF服务的新手,想知道解决以下问题的最佳方法是什么。我有很多客户(约200-约500人),他们在工作日期间都在不断地请求我的服务。大多数请求涉及询问底层数据库以反馈正确的响应。我关心的是传入请求产生的潜在数据库连接数。如果所有客户端同时发出请求,那么数据库服务器将受到重创。如果可能,我想避免与数据库的连接数过多。限制与WCF服务的并发连接数并因此无意中减少可能的数据库连接数会更好吗?我考虑过让服务成为一个单例,它生成线程来执行数据库事务,这样我就可以控制线程的数量,但这是否有点过头了,限制与服务的连接就足够了吗?非常感谢您的任何建议。 最佳答案

c# - 如何在不使用 sqlite 原始语句/conn.execute() 的情况下为 Sqlite.net 设置默认值

我知道这是一个愚蠢的问题,但我无法在任何地方找到答案。如何为sqlite.net模型中的列设置默认值?这是我的模型类:publicclassItemTaxes{[PrimaryKey]publicstringSku{get;set;}publicboolIsTaxable{get;set;}//HowtosetIsTaxable'sdefaultvaluetotrue?publicdecimalPriceTaxExclusive{get;set;}}我想将NotNull列IsTaxable的默认值设置为true,我应该如何实现?顺便说一句,我不想​​使用原始sql语句,即conn.ex

c# - 调用 API 时在哪里使用并发

在一个C#项目中,我正在对WebAPI进行一些调用,问题是我在一个方法的循环中执行它们。通常没有那么多,但即使我在考虑利用并行性。目前我正在尝试的是publicvoidDeployView(intitemId,stringitemCode,intenvironmentTypeId){using(varclient=newHttpClient()){client.BaseAddress=newUri(ConfigurationManager.AppSettings["ApiUrl"]);client.DefaultRequestHeaders.Accept.Clear();client.

c# - 静态方法是否共享其局部变量以及在不同线程并发使用期间会发生什么?

C#问题-我正在尝试确定是否可以使用静态方法,在该方法中它确实有一些它使用的局部变量。局部变量是否在方法的使用中“共享”?例如,如果从不同线程同时调用/使用静态方法,会发生什么情况?一个线程是否阻塞直到另一个线程完成等?也许普遍的问题是,在线程应用程序中,什么时候应该“不”使用静态方法? 最佳答案 方法中的局部变量存在于栈中,每个线程都有自己的栈。因此,多个线程使用该方法是安全的。但是,如果方法本身使用静态变量,那么您应该使用适当的MT保护。您可能调用的外部方法也需要安全...... 关

c# - 执行大量并发 INSERT 时如何避免 "Violation of UNIQUE KEY constraint"

我正在执行许多并发SQLINSERT语句,这些语句在UNIQUEKEY约束上发生冲突,即使我也在单个事务中检查给定键的现有记录。我正在寻找一种方法来消除或最大限度地减少我遇到的碰撞数量,同时又不会损害性能(太多)。背景:我正在开发一个ASP.NETMVC4WebApi项目,该项目接收大量对INSERT记录的HTTPPOST请求。它每秒收到大约5K-10K请求。该项目的唯一职责是删除重复数据和汇总记录。写起来很重;它的读取请求量相对较小;所有这些都使用带有IsolationLevel.ReadUncommitted的事务。数据库架构这是数据库表:CREATETABLE[MySchema]

c# - .NET 4.0 并发收集性能

我正在尝试编写一个程序,在该程序中,我通过将项目放入来自不同线程的集合中并在迭代集合并处理项目的单个线程中清理它们来安排要删除的项目。在这样做之前,我想知道什么会产生最佳性能,所以我尝试了ConcurrentBag、ConcurrentStack和ConcurrentQueue并测量了添加10000000个项目所需的时间。我用下面的程序来测试这个:classProgram{staticListlist=newList();staticConcurrentBagbag=newConcurrentBag();staticConcurrentStackstack=newConcurrentS

c# - 如何使用 Lazy 处理并发请求?

我是C#的新手,正在尝试了解如何使用Lazy。我需要通过等待已运行操作的结果来处理并发请求。数据请求可能会同时使用相同/不同的凭据。对于每组唯一的凭据,最多可以进行一个GetDataInternal调用,该调用的结果会在准备就绪时返回给所有排队的服务员privatereadonlyConcurrentDictionary>Cache=newConcurrentDictionary>();publicDataGetData(Credentialcredential){//Thisinstancewillbethrownawayifacached//valuewithour"credent

c# - HttpWebResponse 不会针对并发出站请求进行扩展

我有一个用C#编写的ASP.NET3.5服务器应用程序。它使用HttpWebRequest和HttpWebResponse向RESTAPI发出出站请求。我已经设置了一个测试应用程序来在单独的线程上发送这些请求(以模糊地模拟针对服务器的并发)。请注意,这更像是一个单声道/环境问题,而不是代码问题;所以请记住下面的代码不是逐字的;只是功能位的剪切/粘贴。这是一些伪代码://threadedclientpieceintnumThreads=1;ManualResetEventdoneEvent;using(doneEvent=newManualResetEvent(false)){for(i

c# - 在 ASP.NET 中每个用户只允许一个并发登录

在ASP.NETWeb应用程序中是否可以允许每个用户同时登录一次?我正在开发一个Web应用程序,我想在其中确保该网站一次只允许每位用户登录一次。如何检查当前用户是否已经登录?请建议我们可以处理此问题的正确登录方法。我认为我们应该使用SQLServersession状态来处理这个问题。你有什么建议?我想到了一个解决方案。我们可以这样做:当用户登录系统时,我们会在用户列中插入sessionID。(我们将使用数据库session,以便我们可以轻松获取所有session相关数据,如isexpired、expiredatetime等)。当同一个用户再次尝试登录时,我们将检查该sessionID列